Skip to content

Latest commit

 

History

History
59 lines (49 loc) · 1.85 KB

5.5.4 - swoole_redis->__call.md

File metadata and controls

59 lines (49 loc) · 1.85 KB

swoole_redis->__call

魔术方法,方法名会映射为Redis指令,参数作为Redis指令的参数。

函数原型

function swoole_redis->__call(string $command, array $params);
  • $command,必须为合法的Redis指令,详细参见Redis指令列表
  • $params的最后一个参数必须为可执行的函数,其他参数必须为字符串

订阅/发布消息

Redis服务器除了作为内存存储之外,还可以作为一个消息通道服务器。SwooleRedis客户端也支持了Redis的订阅/发布消息指令。

与普通的存储指令不同,消息订阅/发布指令不是请求响应式的。

  • 订阅/发布指令没有回调函数,不需要在最后一个参数传入callback
  • 使用订阅/发布消息命名,必须设置onMessage事件回调函数
  • 客户端发出了subscribe命令后,只能执行subscribepsubscribeunsubscribepunsubscribe这4条命令
$client = new swoole_redis;
$client->on('message', function (swoole_redis $client, $result) {
    var_dump($result);
    static $more = false;
    if (!$more and $result[0] == 'message')
    {
        echo "subscribe new channel\n";
        $client->subscribe('msg_1', 'msg_2');
        $client->unsubscribe('msg_0');
        $more = true;
    }
});
$client->connect('127.0.0.1', 6379, function (swoole_redis $client, $result) {
    echo "connect\n";
    $client->subscribe('msg_0');
});

回调函数

function callback(swoole_redis $redis, bool $result);
  • $redis: redis连接对象
  • 执行失败,$result为false, 可以读取$redis->errCode获得错误码,读取$redis->errMsg获得错误消息
  • 执行成功,返回数据结果,可能是字符串、数组或true

使用示例

$client->get('key', function (swoole_redis $client, $result) {
	var_dump($result);
});